home *** CD-ROM | disk | FTP | other *** search
/ Aminet 48 / Aminet 48 (2002)(GTI - Schatztruhe)[!][Apr 2002].iso / Aminet / text / edit / vim60rt.lha / Vim / vim60 / doc / os_beos.txt < prev    next >
Encoding:
Text File  |  2001-09-26  |  12.4 KB  |  347 lines

  1. *os_beos.txt*    For Vim version 6.0.  Last change: 2001 Sep 03
  2.  
  3.  
  4.           VIM REFERENCE MANUAL    by Bram Moolenaar
  5.  
  6.  
  7.                             *BeOS* *BeBox*
  8. This is a port of Vim 5.1 to the BeOS Preview Release 2 (also known as PR2)
  9. or later.
  10.  
  11. This file contains the particularities for the BeBox/BeOS version of Vim.  For
  12. matters not discussed in this file, Vim behaves very much like the Unix
  13. |os_unix.txt| version.
  14.  
  15.  1. General            |beos-general|
  16.  2. Compiling Vim        |beos-compiling|
  17.  3. Timeout in the Terminal    |beos-timeout|
  18.  4. Unicode vs. Latin1        |beos-unicode|
  19.  5. The BeOS GUI        |beos-gui|
  20.  6. The $VIM directory        |beos-vimdir|
  21.  7. Drag & Drop            |beos-dragndrop|
  22.  8. Single Launch vs. Multiple
  23.     Launch            |beos-launch|
  24.  9. Fonts            |beos-fonts|
  25. 10. The meta key modifier    |beos-meta|
  26. 11. Mouse key mappings        |beos-mouse|
  27. 12. Color names            |beos-colors|
  28. 13. Compiling with Perl        |beos-perl|
  29.  
  30.  
  31. 1. General                        *beos-general*
  32.  
  33. The default syntax highlighting mostly works with different foreground colors
  34. to highlight items. This works best if you set your Terminal window to a
  35. darkish background and light letters. Some middle-grey background (for
  36. instance (r,g,b)=(168,168,168)) with black letters also works nicely.  If you
  37. use the default light background and dark letters, it may look better to
  38. simply reverse the notion of foreground and background color settings. To do
  39. this, add this to your .vimrc file (where <Esc> may need to be replaced with
  40. the escape character): >
  41.  
  42.   :if &term == "beos-ansi"
  43.   :    set t_AB=<Esc>[3%dm
  44.   :    set t_AF=<Esc>[4%dm
  45.   :endif
  46.  
  47.  
  48. 2. Compiling Vim                    *beos-compiling*
  49.  
  50. From the Advanced Access Preview Release (AAPR) on, Vim can be configured with
  51. the standard configure script. To get the compiler and its flags right, use
  52. the following command-line in the shell (you can cut and paste it in one go):
  53.  
  54. CC=$BE_C_COMPILER CFLAGS="$BE_DEFAULT_C_FLAGS -O7" \
  55.     ./configure --prefix=/boot/home/config
  56.  
  57. $BE_C_COMPILER is usually "mwcc", $BE_DEFAULT_C_FLAGS is usually "-I- -I."
  58.  
  59. When configure has run, and you wish to enable GUI support, you must edit the
  60. config.mk file so that the lines with GUI_xxx refer to $(BEOSGUI_xxx) instead
  61. of $(NONE_xxx).
  62. Alternatively you can make this change in the Makefile; it will have a
  63. more permanent effect. Search for "NONE_".
  64.  
  65. After compilation you need to add the resources to the binary. Add the
  66. following few lines near the end (before the line with "exit $exit_value") of
  67. the link.sh script to do this automatically.
  68.  
  69.     rmattr BEOS:TYPE vim
  70.     copyres os_beos.rsrc vim
  71.     mimeset vim
  72.  
  73. Also, create a dummy file "strip":
  74.  
  75.     #!/bin/sh
  76.     mimeset $1
  77.     exit 0
  78.  
  79. You will need it when using "make install" to install Vim.
  80.  
  81. Now type "make" to compile Vim, then "make install" to install it.
  82.  
  83. If you want to install Vim by hand, you must copy Vim to $HOME/config/bin, and
  84. create a bunch of symlinks to it ({g,r,rg}{vim,ex,view}). Furthermore you must
  85. copy Vims configuration files to $HOME/config/share/vim:
  86. vim-5.0s/{*.vim,doc,syntax}.  For completeness, you should also copy the nroff
  87. manual pages to $HOME/config/man/man1. Don't forget ctags/ctags and xxd/xxd!
  88.  
  89. Obviously, you need the unlimited linker to actually link Vim. See
  90. http://www.metrowerks.com for purchasing the CodeWarrior compiler for BeOS.
  91. There are currently no other linkers that can do the job.
  92.  
  93. This won't be able to include the Perl or Python interfaces even if
  94. you have the appropriate files installed. |beos-perl|
  95.  
  96.  
  97. 3. Timeout in the Terminal                *beos-timeout*
  98.  
  99. Because some POSIX/UNIX features are still missing[1], there is no direct OS
  100. support for read-with-timeout in the Terminal. This would meat that you cannot
  101. use :mappings of more than one character, unless you also :set notimeout.
  102. |'timeout'|
  103.  
  104. To circumvent this problem, I added a workaround to provide the necessary
  105. input with timeout by using an extra thread which reads ahead one character.
  106. As a side effect, it also makes Vim recognize when the Terminal window
  107. resizes.
  108.  
  109. Function keys are not supported in the Terminal since they produce very
  110. indistinctive character sequences.
  111.  
  112. These problems do not exist in the GUI.
  113.  
  114. [1]: there is no select() on file descriptors; also the termios VMIN and VTIME
  115. settings do not seem to work properly. This has been the case since DR7 at
  116. least and still has not been fixed as of PR2.
  117.  
  118.                             *beos-unicode*
  119. 4. Unicode vs. Latin1                    *beos-utf8*
  120.  
  121. BeOS uses Unicode and UTF-8 for text strings (16-bit characters encoded to
  122. 8-bit characters). Vim assumes ISO-Latin1 or other 8-bit character codes.
  123. This does not produce the desired results for non-ASCII characters. Try the
  124. command :digraphs to see. If they look messed up, use :set isprint=@ to
  125. (slightly) improve the display of ISO-Latin1 characters 128-255.  This works
  126. better in the GUI, depending on which font you use (below).
  127.  
  128. You may also use the /boot/bin/xtou command to convert UTF-8 files from (xtou
  129. -f iso1 filename) or to (xtou -t iso1 filename) ISO-Latin1 characters.
  130.  
  131.  
  132. 5. The BeOS GUI                        *beos-gui*
  133.  
  134. Normally Vim starts with the GUI if you start it as gvim or vim -g.  The BeOS
  135. version tries to determine if it was started from the Tracker instead of the
  136. Terminal, and if so, use the GUI anyway. However, the current detection scheme
  137. is fooled if you use the command "vim - </dev/null" or "vim filename &". The
  138. latter can be called a feature but probably only works because there is no
  139. BSD-style job control.
  140.  
  141. Stuff that does not work yet:
  142.  
  143. - Running external commands from the GUI does not work 100% (again due to lack
  144.   of support for select()). There was a choice between seeing the command's
  145.   output, or being able to interrupt it. I chose for seeing the output. Even
  146.   now the command sometimes crashes mysteriously, apparently in Be's
  147.   malloc_internal() called from the putenv() function, after fork()ing. (data
  148.   access exception occurred, ec01b0ec:  90e80000 *stw r7, 0x0000 (r8))(:!ls
  149.   works usually, :r !ls usually doesn't). This has been reported as bug
  150.   # 971215-083826.
  151. - The window title.
  152. - Starting the GUI from the Terminal version with :gui always acts as if
  153.   :gui -f were used. There is no way to fix this that I can see.
  154. - There are some small display glitches here and there that I hope to clean up
  155.   later. Most of them occur when the window is partially obscured. Some of
  156.   them seem to be bugs in BeOS, because the Terminal has similar glitches.
  157. - Mouse up events are not generated when outside the window. This is a bug in
  158.   BeOS. You can notice this when selecting text and moving the cursor outside
  159.   the window, then letting go of the mouse button.  Another way is when you
  160.   drag the scrollbar and do the same thing.  Because Vim still thinks you are
  161.   still playing with the scrollbar it won't change it itself. I provided a
  162.   workaround which kicks in when the window is activated or deactivated (so it
  163.   works best with focus- follows-mouse (/boot/bin/ffm) turned on).
  164. - The cursor does not flash (very low priority; I'm not sure I even like it
  165.   when it flashes)
  166.  
  167.  
  168. The $VIM directory                    *beos-vimdir*
  169.  
  170. $VIM is the symbolic name for the place where Vims support files are stored.
  171. The default value for $VIM is set at compile time and can be determined with >
  172.  
  173.   :version
  174.  
  175. The normal value is /boot/home/config/share/vim. If you don't like it you can
  176. set the VIM environment variable to override this, or set 'helpfile' in your
  177. .vimrc: >
  178.  
  179.   :if version >= 500
  180.   :    set helpfile=~/vim/vim54/doc/help.txt
  181.   :    syntax on
  182.   :endif
  183.  
  184.  
  185. 7. Drag & Drop                        *beos-dragndrop*
  186.  
  187. You can drop files and directories on either the Vim icon (starts a new Vim
  188. session, unless you use the File Types application to set Vim to be "Single
  189. Launch") or on the Vim window (starts editing the files).  Dropping a folder
  190. sets Vim's current working directory. |:cd| |:pwd| If you drop files or
  191. folders with either SHIFT key pressed, Vim changes directory to the folder
  192. that contains the first item dropped. When starting Vim, there is no need to
  193. press shift: Vim behaves as if you do.
  194.  
  195. Files dropped set the current argument list. |argument-list|
  196.  
  197.  
  198. 8. Single Launch vs. Multiple Launch            *beos-launch*
  199.  
  200. As distributed Vim's Application Flags (as seen in the FileTypes preference)
  201. are set to Multiple Launch. If you prefer, you can set them to Single Launch
  202. instead.  Attempts to start a second copy of Vim will cause the first Vim to
  203. open the files instead. This works from the Tracker but also from the command
  204. line. In the latter case, non-file (option) arguments are not supported.
  205.  
  206. NB: Only the GUI version has a BApplication (and hence Application Flags).
  207. This section does not apply to the GUI-less version, should you compile one.
  208.  
  209.  
  210. 9. Fonts                        *beos-fonts*
  211.  
  212. Set fonts with >
  213.  
  214.   :set guifont=Courier10_BT/Roman/10
  215.  
  216. where the first part is the font family, the second part the style, and the
  217. third part the size. You can use underscores instead of spaces in family and
  218. style.
  219.  
  220. Best results are obtained with monospaced fonts (such as Courier). Vim
  221. attempts to use all fonts in B_FIXED_SPACING mode but apparently this does not
  222. work for proportional fonts (despite what the BeBook says).
  223.  
  224. Vim also tries to use the B_ISO8859_1 encoding, also known as ISO Latin 1.
  225. This also does not work for all fonts. It does work for Courier, but not for
  226. ProFontISOLatin1/Regular (strangely enough). You can verify this by giving the >
  227.  
  228.   :digraphs
  229.  
  230. command, which lists a bunch of characters with their ISO Latin 1 encoding.
  231. If, for instance, there are "box" characters among them, or the last character
  232. isn't a dotted-y, then for this font the encoding does not work.
  233.  
  234. If the font you specify is unavailable, you get the system fixed font.
  235.  
  236. Standard fixed-width system fonts are:
  237.  
  238.           ProFontISOLatin1/Regular
  239.           Courier10_BT/Roman
  240.           Courier10_BT/Italic
  241.           Courier10_BT/Bold
  242.           Courier10_BT/Bold_Italic
  243.  
  244. Standard proportional system fonts are:
  245.  
  246.             Swis721_BT/Roman
  247.             Swis721_BT/Italic
  248.             Swis721_BT/Bold
  249.             Swis721_BT/Bold_Italic
  250.         Dutch801_Rm_BT/Roman
  251.         Dutch801_Rm_BT/Italic
  252.         Dutch801_Rm_BT/Bold
  253.         Dutch801_Rm_BT/Bold_Italic
  254.            Baskerville/Roman
  255.            Baskerville/Italic
  256.            Baskerville/Bold
  257.            Baskerville/Bold_Italic
  258.          SymbolProp_BT/Regular
  259.  
  260. Try some of them, just for fun.
  261.  
  262.  
  263. 10. The meta key modifier                *beos-meta*
  264.  
  265. The META key modifier is obtained by the left or right OPTION keys.  This is
  266. because the ALT (aka COMMAND) keys are not passed to applications.
  267.  
  268.  
  269. 11. Mouse key mappings                    *beos-mouse*
  270.  
  271. Vim calls the various mouse buttons LeftMouse, MiddleMouse and RightMouse.  If
  272. you use the default Mouse preference settings these names indeed correspond to
  273. reality. Vim uses this mapping:
  274.  
  275.     Button 1 -> LeftMouse,
  276.     Button 2 -> RightMouse,
  277.     Button 3 -> MiddleMouse.
  278.  
  279. If your mouse has fewer than 3 buttons you can provide your own mapping from
  280. mouse clicks with modifier(s) to other mouse buttons. See the file
  281. vim-5.x/macros/swapmous.vim for an example.        |gui-mouse-mapping|
  282.  
  283.  
  284. 12. Color names                        *beos-colors*
  285.  
  286. Vim has a number of color names built-in. Additional names are read from the
  287. file $VIMRUNTIME/rgb.txt, if present. This file is basically the color
  288. database from X. Names used from this file are cached for efficiency.
  289.  
  290.  
  291. 13. Compiling with Perl                    *beos-perl*
  292.  
  293. Compiling with Perl support enabled is slightly tricky. The Metrowerks
  294. compiler has some strange ideas where to search for include files. Since
  295. several include files with Perl have the same names as some Vim header
  296. files, the wrong ones get included. To fix this, run the following Perl
  297. script while in the vim-5.0/src directory: >
  298.  
  299.    preproc.pl > perl.h
  300.  
  301.     #!/bin/env perl
  302.     # Simple #include expander, just good enough for the Perl header files.
  303.  
  304.     use strict;
  305.     use IO::File;
  306.     use Config;
  307.  
  308.     sub doinclude
  309.     {
  310.     my $filename = $_[0];
  311.     my $fh = new IO::File($filename, "r");
  312.     if (defined $fh) {
  313.         print "/* Start of $filename */\n";
  314.  
  315.         while (<$fh>) {
  316.         if (/^#include "(.*)"/) {
  317.             doinclude($1);
  318.             print "/* Back in $filename */\n";
  319.         } else {
  320.             print $_;
  321.         }
  322.         }
  323.         print "/* End of $filename */\n";
  324.  
  325.         undef $fh;
  326.     } else {
  327.         print "/* Cannot open $filename */\n";
  328.         print "#include \"$filename\"\n";
  329.     }
  330.     }
  331.  
  332.     chdir     $Config{installarchlib}."/CORE";
  333.     doinclude "perl.h";
  334.  
  335. It expands the "perl.h" header file, using only other Perl header files.
  336.  
  337. Now you can configure & make Vim with the --enable-perlinterp option.
  338. Be warned though that this adds about 616 kilobytes to the size of Vim!
  339. Without Perl, Vim with default features and GUI is about 575K, with Perl
  340. it is about 1191K.
  341.  
  342. -Olaf Seibert
  343. <rhialto@polder.ubc.kun.nl>
  344. http://polder.ubc.kun.nl/~rhialto/be
  345.  
  346.  vim:tw=78:fo=tcq2:isk=!-~,^*,^\|,^\":ts=8:ft=help:norl:
  347.